Unregister the popover before destroying it
authorWilliam Jon McCann <william.jon.mccann@gmail.com>
Fri, 21 Feb 2014 18:43:55 +0000 (13:43 -0500)
committerWilliam Jon McCann <william.jon.mccann@gmail.com>
Fri, 21 Feb 2014 19:51:25 +0000 (14:51 -0500)
Fixes a leak of the registered_windows list in GtkWidget.

https://bugzilla.gnome.org/show_bug.cgi?id=554618

gtk/gtkwindow.c

index 7d37b6f165758cbb000f4e47e27f31c622c4bb11..befca5ac85efb6959d4f6a02672487368c85e6fe 100644 (file)
@@ -1338,8 +1338,18 @@ popover_destroy (GtkWindowPopover *popover)
       popover->unmap_id = 0;
     }
 
-  if (popover->widget && gtk_widget_get_parent (popover->widget))
-    gtk_widget_unparent (popover->widget);
+  if (popover->widget)
+    {
+      GtkWidget *parent;
+
+      parent = gtk_widget_get_parent (popover->widget);
+
+      if (parent)
+        {
+          gtk_widget_unregister_window (parent, popover->window);
+          gtk_widget_unparent (popover->widget);
+        }
+    }
 
   if (popover->window)
     gdk_window_destroy (popover->window);
@@ -6252,8 +6262,10 @@ gtk_window_realize (GtkWidget *widget)
 
 static void
 popover_unrealize (GtkWidget        *widget,
-                   GtkWindowPopover *popover)
+                   GtkWindowPopover *popover,
+                   GtkWindow        *window)
 {
+  gtk_widget_unregister_window (GTK_WIDGET (window), popover->window);
   gtk_widget_unrealize (popover->widget);
   gdk_window_destroy (popover->window);
   popover->window = NULL;
@@ -6316,7 +6328,7 @@ gtk_window_unrealize (GtkWidget *widget)
     {
       GtkWindowPopover *popover = link->data;
       link = link->next;
-      popover_unrealize (popover->widget, popover);
+      popover_unrealize (popover->widget, popover, window);
     }
 
   GTK_WIDGET_CLASS (gtk_window_parent_class)->unrealize (widget);